import request from "@/utils/request";

const MONTHLYSETTLEMENTS_BASE_URL = "/api/v1/monthly-settlements";

const MonthlySettlementsAPI = {
  /** 获取月度结算单分页数据 */
  getPage(queryParams?: MonthlySettlementsPageQuery) {
    return request<any, PageResult<MonthlySettlementsPageVO[]>>({
      url: `${MONTHLYSETTLEMENTS_BASE_URL}/page`,
      method: "get",
      params: queryParams,
    });
  },
  /**
   * 获取月度结算单表单数据
   *
   * @param id 月度结算单ID
   * @returns 月度结算单表单数据
   */
  getFormData(id: number) {
    return request<any, MonthlySettlementsForm>({
      url: `${MONTHLYSETTLEMENTS_BASE_URL}/${id}/form`,
      method: "get",
    });
  },

  /**
   *  添加月度结算单
   *
   *  @param data 月度结算单表单数据
   */
  add(data: MonthlySettlementsForm) {
    return request({
      url: `${MONTHLYSETTLEMENTS_BASE_URL}`,
      method: "post",
      data,
    });
  },

  /**
   * 更新月度结算单
   *
   * @param id 月度结算单ID
   * @param data 月度结算单表单数据
   */
  update(id: number, data: MonthlySettlementsForm) {
    return request({
      url: `${MONTHLYSETTLEMENTS_BASE_URL}/${id}`,
      method: "put",
      data,
    });
  },

  /**
   * 批量删除月度结算单，多个以英文逗号(,)分割
   *
   * @param ids 月度结算单ID字符串，多个以英文逗号(,)分割
   */
  deleteByIds(ids: string) {
    return request({
      url: `${MONTHLYSETTLEMENTS_BASE_URL}/${ids}`,
      method: "delete",
    });
  },
};

export default MonthlySettlementsAPI;

/** 月度结算单分页查询参数 */
export interface MonthlySettlementsPageQuery extends PageQuery {}

/** 月度结算单表单对象 */
export interface MonthlySettlementsForm {
  id?: number;
  /** 结算单编号(如JS202307001) */
  settlementNumber?: string;
  /** 客户ID */
  customerId?: number;
  /** 客户名称(冗余存储) */
  customerName?: string;
  /** 结算年月(YYYY-MM) */
  yearMonth?: string;
  /** 结算开始日期 */
  startDate?: Date;
  /** 结算结束日期 */
  endDate?: Date;
  /** 总数量 */
  totalQuantity?: number;
  /** 总金额 */
  totalAmount?: number;
  /** 状态:0-草稿 1-已确认 2-已付款 */
  status?: number;
  /** 备注 */
  remark?: string;
  /** 创建人ID */
  createBy?: number;
  /** 创建时间 */
  createTime?: Date;
  /** 修改人ID */
  updateBy?: number;
  /** 更新时间 */
  updateTime?: Date;
}

/** 月度结算单分页对象 */
export interface MonthlySettlementsPageVO {
  id?: number;
  /** 结算单编号(如JS202307001) */
  settlementNumber?: string;
  /** 客户ID */
  customerId?: number;
  /** 客户名称(冗余存储) */
  customerName?: string;
  /** 结算年月(YYYY-MM) */
  yearMonth?: string;
  /** 结算开始日期 */
  startDate?: Date;
  /** 结算结束日期 */
  endDate?: Date;
  /** 总数量 */
  totalQuantity?: number;
  /** 总金额 */
  totalAmount?: number;
  /** 状态:0-草稿 1-已确认 2-已付款 */
  status?: number;
  /** 备注 */
  remark?: string;
  /** 创建人ID */
  createBy?: number;
  /** 创建时间 */
  createTime?: Date;
  /** 修改人ID */
  updateBy?: number;
  /** 更新时间 */
  updateTime?: Date;
}
